﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Input;
using System.Windows.Controls;
using System.Windows;
using System.Windows.Threading;

namespace DisplayBoardInfoClient
{
    /// <summary>
    /// Klasa będąca rozszerzeniem zwykłego menu. Dodatkowa funkcjonalność polaga na chowaniu menu po upływie odpowiedniego czasu, jeżeli
    /// nie ma ruchu kursora.
    /// Pozwala to na schowanie menu i pozostaweienie okna w pełni wypełnionego treścią.
    /// </summary>
    public class AutoHideMenu : Menu
    {
        DispatcherTimer timer;

        private Int32 _autoHideDelay;
        /// <summary>
        /// Czas sekundach po którym menu zostanie schowane w przypadku braku odpowiedniej akcji.
        /// </summary>
        public Int32 AutoHideDelay
        {
            get
            {
                return _autoHideDelay;
            }
            set
            {
                _autoHideDelay = value;
                timer.Interval = TimeSpan.FromSeconds(AutoHideDelay);
            }
        }
        /// <summary>
        /// Podstawowy konstruktor tworzący obiekt klasy.
        /// </summary>
        public AutoHideMenu()
        {
            MouseMove += new MouseEventHandler(AutoHideMenuItem_MouseOver);
            

            timer = new DispatcherTimer(DispatcherPriority.Normal, Dispatcher);
            timer.Interval = TimeSpan.FromSeconds(AutoHideDelay);
            timer.Stop();

            timer.Tick += new EventHandler(timer_Tick);
        }
        /// <summary>
        /// Metoda wykonująca ukrycie menu po odpowiednim czasie. Zmienia paramert Visible na hidden.
        /// </summary>
        /// <param name="sender">obiekt wysyłający zdarzenie</param>
        /// <param name="e">dodatkowe parametry zdarzenia nie wykorzystywane w metodzie</param>
        void timer_Tick(object sender, EventArgs e)
        {
            this.Visibility = System.Windows.Visibility.Hidden;
        }
        /// <summary>
        /// Metoda wykonująca pojawienie się menu po wykonaniu akcji, oraz resetująca zegar odmierzający czas do ukrycia menu.
        /// </summary>
        /// <param name="sender">obiekt wysyłający zdarzenie</param>
        /// <param name="e">dodatkowe parametry zdarzenia nie wykorzystywane w metodzie</param>
        public void AutoHideMenuItem_MouseOver(object sender, MouseEventArgs e)
        {
            timer.Stop();
            this.Visibility = System.Windows.Visibility.Visible;
            timer.Start();
        }
    }
}
